using Ln.Fram.Ddd.Application;
using Ln.Fram.SqlSugarCore.Abstractions;
using Ln.Rbac.Application.Contracts.Dtos.Menu;
using Ln.Rbac.Application.Contracts.IServices;
using Ln.Rbac.Domain.Entities;
using SqlSugar;
using Volo.Abp.Application.Dtos;

namespace Ln.Fram.Rbac.Application.Services.System;

/// <summary>
/// Menu服务实现
/// </summary>
public class MenuService : LnCrudAppService<MenuAggregateRoot, MenuGetOutputDto, MenuGetListOutputDto, Guid, MenuGetListInputVo, MenuCreateInputVo, MenuUpdateInputVo>, IMenuService
{
	private readonly ISqlSugarRepository<MenuAggregateRoot, Guid> _repository;
	public MenuService(ISqlSugarRepository<MenuAggregateRoot, Guid> repository) : base(repository)
	{
		_repository = repository;
	}

	public override async Task<PagedResultDto<MenuGetListOutputDto>> GetListAsync(MenuGetListInputVo input)
	{
		RefAsync<int> total = 0;
		var entities = await _repository._DbQueryable.WhereIF(!string.IsNullOrEmpty(input.MenuName), x => x.MenuName.Contains(input.MenuName!))
			.WhereIF(input.State is not null, x => x.State == input.State)
			.Where(x => x.MenuSource == input.MenuSource)
			.OrderByDescending(x => x.OrderNum)
			.ToListAsync();
		return new PagedResultDto<MenuGetListOutputDto>(total, await MapToGetListOutputDtosAsync(entities));
	}

	/// <summary>
	/// 查询当前角色的菜单
	/// </summary>
	/// <param name="roleId"></param>
	/// <returns></returns>
	public async Task<List<MenuGetListOutputDto>> GetListRoleIdAsync(Guid roleId)
	{
		var entities = await _repository._DbQueryable.Where(m => SqlFunc.Subqueryable<RoleMenuEntity>().Where(rm => rm.RoleId == roleId && rm.MenuId == m.Id).Any()).ToListAsync();
		return await MapToGetListOutputDtosAsync(entities);
	}
}
